// 使用export.module的原因是vue-cli运行在nodejs环境
const path = require('path') // 引入node的路径处理模块
const isProduction = process.env.NODE_ENV === 'production'
const isPreTest = process.env.VUE_APP_MODE === 'test' || process.env.VUE_APP_MODE === 'pre'

function resolve(dir) {
  // __dirname 项目根目录的绝对路径
  return path.join(__dirname, dir)
}

module.exports = {
  publicPath: isPreTest ? '/cons/' : '/',
  productionSourceMap: isProduction ? false : true,
  chainWebpack(config) {
    config.module.rule('svg').exclude.add(resolve('src/assets/svg'))
    config.module
      .rule('assets')
      .test(/\.(svg)(\?.*)?$/)
      .include.add(resolve('src/assets/svg'))
      .end()
      .use('svg-sprite-loader')
      .loader('svg-sprite-loader')
      .options({ symbolId: 'icon-[name]' })
    config.externals({
      BMapGL: 'BMapGL',
      BMapGLLib: 'BMapGLLib'
    })
  }
}
